home *** CD-ROM | disk | FTP | other *** search
/ Developer CD Series 1994 February: Tool Chest / Dev.CD Feb 94.toast / New System Software Extensions / QuickDraw™ GX v1.0ß2 / Interfaces & Libraries / interfaces / Messages.h < prev    next >
Encoding:
C/C++ Source or Header  |  1993-07-29  |  11.0 KB  |  425 lines  |  [TEXT/MPS ]

  1. /* ------------------------------------------------------------------------------
  2.  
  3.     FILENAME
  4.         Messages.h
  5.  
  6.     DESCRIPTION
  7.         This file contains all of the public data structures, constants, and 
  8.         function declarations for the Message Manager.
  9.  
  10.     COPYRIGHT
  11.         Copyright © Apple Computer, Inc. 1989, 1990, 1991, 1992, 1993
  12.         All rights reserved. 
  13.  
  14. ------------------------------------------------------------------------------- */
  15.  
  16.  
  17. #ifndef __MESSAGEMANAGER__
  18. #define __MESSAGEMANAGER__
  19.  
  20. #ifndef __TYPES__
  21. #include <Types.h>
  22. #endif
  23.  
  24.  
  25. /*************/
  26. /* Constants */
  27. /*************/
  28.  
  29.  
  30. /* Message Manager Gestalt Selector... */
  31.  
  32.  
  33. enum {
  34.     gestaltMessageMgrVersion = 'mess'
  35. };
  36.  
  37.  
  38. /* Message Manager Error Result Codes... */
  39.  
  40.  
  41. enum {
  42.     messageStopLoopingErr = -5775,
  43.     cantDeleteRunningHandlerErr = -5776,
  44.     noMessageTableErr = -5777,
  45.     dupSignatureErr = -5778,
  46.  
  47.     messageNotReceivedErr = -5799
  48. };
  49.  
  50.  
  51. /* Message Manager Class Options... */
  52.  
  53.  
  54. enum {
  55.     messageClassNoOptions         = 0x00000000,
  56.     messageClassIgnoreResult    = 0x80000000
  57. };
  58.  
  59.  
  60. /* Message Manager Useful Constants... */
  61.  
  62.  
  63. enum {
  64.     topMessageHandler     = 0                /* indicates top handler when position is expected */
  65. };
  66.  
  67.  
  68. /* the Message Manager trap */
  69.  
  70.  
  71. #define messageManagerTrap 0xABFB    /* C++ will choke on an enum in a trap definition */
  72.  
  73.  
  74. /* Message Manager Selectors... */
  75.  
  76.  
  77. #define sendObjectMessageSelector 0x702F
  78. #define sendObjectMessageToSelector 0x7030
  79. #define startObjectMessageAtSelector 0x7031
  80. #define sendMessageSelector 0x7032
  81. #define sendMessageToSelector 0x7033
  82. #define startMessageAtSelector 0x7034
  83. #define forwardSelector 0x7035
  84. #define forwardThisSelector 0x7036
  85.  
  86.  
  87. /*************/
  88. /* Macros      */
  89. /*************/
  90.  
  91.  
  92. /* the SendObjectMessageGlue macro assumes the message target is in register A0 */
  93.  
  94. #define SendObjectMessageGlue(table, selector) {                                    \
  95.     sendObjectMessageSelector, 0x223C, table, selector, messageManagerTrap    \
  96. }
  97.  
  98. #define SendMessageGlue(table, selector) {                                    \
  99.     sendMessageSelector, 0x223C, table, selector, messageManagerTrap    \
  100. }
  101.  
  102. #define ForwardMessageGlue(table, selector) {                            \
  103.     forwardSelector, 0x223C, table, selector, messageManagerTrap    \
  104. }
  105.  
  106. #define ForwardThisMessageGlue { forwardThisSelector, messageManagerTrap }
  107.  
  108.  
  109.  
  110. /*************/
  111. /* Types      */
  112. /*************/
  113.  
  114.  
  115. typedef struct PrivateMessageClassRecord *MessageClass;        /* abstract data type for message class */
  116.  
  117. typedef struct PrivateMessageHandlerRecord *MessageHandler;    /* abstract data type for message handler */
  118.  
  119. typedef struct PrivateMessageObjectRecord *MessageObject;    /* abstract data type for message object */
  120.  
  121.  
  122. /* definition of an override table... */
  123.  
  124.  
  125. typedef struct {
  126.     short        messageID;        /* message being overridden */
  127.     long        dispatch1;        /* first dispatch selector */
  128.     long        dispatch2;        /* second dispatch selector */
  129. } MessageOverride;
  130.  
  131.  
  132. typedef struct {
  133.     short                    numOverrides;
  134.     MessageOverride    overrides[1];
  135. } MessageOverrideTable, *MessageOverrideTablePtr;
  136.  
  137.  
  138. typedef OSType Signature;
  139.  
  140. typedef void* MessageStackMark[2];
  141.  
  142.  
  143. #ifdef __cplusplus
  144. extern "C" {
  145. #endif
  146.  
  147.  
  148. typedef void (*MessageHandlerSetupProc) (void *handlerData);
  149.  
  150. typedef OSErr (*MessageClassExceptionProc) (MessageObject, OSErr);
  151.  
  152. typedef OSErr (*MessageObjectLoopProc) (MessageObject, void *refCon);
  153.  
  154. typedef OSErr (*MessageHandlerLoopProc) (MessageHandler, void *refCon);
  155.  
  156. typedef void (*MessageGlobalsInitProc) (void *messageGlobals);
  157.  
  158.  
  159.  
  160. /**********************************************************************
  161.  ***************            Public Interfaces            ***********************
  162.  *********************************************************************/
  163.  
  164.  
  165.  
  166. /* **************************************** */
  167. /* Message Class Management API Routines... */
  168. /* **************************************** */
  169.  
  170.  
  171.  
  172. MessageClass NewMessageClass (long numTables, long classOptions)
  173. = {0x7000, messageManagerTrap};
  174.  
  175. void DisposeMessageClass (MessageClass)
  176. = {0x7001, messageManagerTrap};
  177.  
  178. MessageClass CloneMessageClass (MessageClass)
  179. = {0x7002, messageManagerTrap};
  180.  
  181. long CountMessageClassOwners (MessageClass)
  182. = {0x7003, messageManagerTrap};
  183.  
  184. MessageClass NewDerivedMessageClass (MessageClass parentClass)
  185. = {0x7004, messageManagerTrap};
  186.  
  187. void *SetMessageClassDispatchProc (MessageClass, void *dispatchProc)
  188. = {0x7005, messageManagerTrap};
  189.  
  190. MessageHandlerSetupProc SetMessageClassHandlerSetupProc (MessageClass, MessageHandlerSetupProc)
  191. = {0x7006, messageManagerTrap};
  192.  
  193. MessageHandlerSetupProc SetMessageClassHandlerReturnProc (MessageClass, MessageHandlerSetupProc)
  194. = {0x7007, messageManagerTrap};
  195.  
  196. MessageClassExceptionProc SetMessageClassExceptionProc (MessageClass, MessageClassExceptionProc)
  197. = {0x7008, messageManagerTrap};
  198.  
  199. void *GetMessageClassRefCon (MessageClass)
  200. = {0x7009, messageManagerTrap};
  201.  
  202. void *SetMessageClassRefCon (MessageClass, void *refCon)
  203. = {0x700A, messageManagerTrap};
  204.  
  205. OSErr NewMessageHandler (MessageClass,
  206.                                  long handlerPos,
  207.                                  MessageOverrideTablePtr overrideTableList[],
  208.                                  void *handlerData,
  209.                                  Signature handlerSig,
  210.                                  MessageHandler *msgHandler)
  211. = {0x700B, messageManagerTrap};
  212.  
  213. OSErr RemoveMessageHandler (MessageClass, MessageHandler)
  214. = {0x700C, messageManagerTrap};
  215.  
  216. OSErr InstallMessageHandlerOverride (MessageClass,
  217.                                                  MessageHandler,
  218.                                                  long messageSelector,
  219.                                                  long dispatch1,
  220.                                                  long dispatch2)
  221. = {0x700D, messageManagerTrap};
  222.  
  223. void RemoveMessageHandlerOverride (MessageClass,
  224.                                               MessageHandler,
  225.                                               long messageSelector)
  226. = {0x700E, messageManagerTrap};
  227.  
  228. void *GetMessageHandlerData (MessageClass, MessageHandler)
  229. = {0x700F, messageManagerTrap};
  230.  
  231. void *SetMessageHandlerData (MessageClass,
  232.                                       MessageHandler,
  233.                                       void *handlerData)
  234. = {0x7010, messageManagerTrap};
  235.  
  236. void DisableMessageHandler (MessageClass, MessageHandler)
  237. = {0x7011, messageManagerTrap};
  238.  
  239. void EnableMessageHandler (MessageClass, MessageHandler)
  240. = {0x7012, messageManagerTrap};
  241.  
  242. int MessageHandlerDisabled (MessageClass, MessageHandler)
  243. = {0x7013, messageManagerTrap};
  244.  
  245. long CountMessageHandlers (MessageClass)
  246. = {0x7014, messageManagerTrap};
  247.  
  248. MessageHandler GetMessageHandlerAt (MessageClass, long handlerPosition)
  249. = {0x7015, messageManagerTrap};
  250.  
  251. Signature GetMessageHandlerSignature (MessageClass, MessageHandler)
  252. = {0x7016, messageManagerTrap};
  253.  
  254. MessageHandler FindMessageHandler (MessageClass, Signature)
  255. = {0x7017, messageManagerTrap};
  256.  
  257. long GetMessageHandlerPosition (MessageClass, MessageHandler)
  258. = {0x7018, messageManagerTrap};
  259.  
  260. OSErr ForEachMessageHandlerDo (MessageClass, MessageHandlerLoopProc, void *refCon)
  261. = {0x7019, messageManagerTrap};
  262.  
  263.  
  264.  
  265. /* ***************************************** */
  266. /* Message Object Management API Routines... */
  267. /* ***************************************** */
  268.  
  269.  
  270.  
  271. MessageObject NewMessageObject (MessageClass)
  272. = {0x701A, messageManagerTrap};
  273.  
  274. void DisposeMessageObject (MessageObject)
  275. = {0x701B, messageManagerTrap};
  276.  
  277. MessageObject CloneMessageObject (MessageObject)
  278. = {0x701C, messageManagerTrap};
  279.  
  280. long CountMessageObjectOwners (MessageObject)
  281. = {0x701D, messageManagerTrap};
  282.  
  283. void *GetMessageObjectRefCon (MessageObject)
  284. = {0x701E, messageManagerTrap};
  285.  
  286. void *SetMessageObjectRefCon (MessageObject, void *)
  287. = {0x701F, messageManagerTrap};
  288.  
  289. MessageClass GetMessageObjectClass (MessageObject)
  290. = {0x7020, messageManagerTrap};
  291.  
  292. long CountMessageObjects (MessageClass)
  293. = {0x7021, messageManagerTrap};
  294.  
  295. OSErr ForEachMessageObjectDo (MessageClass, MessageObjectLoopProc, void *refCon)
  296. = {0x7022, messageManagerTrap};
  297.  
  298.  
  299.  
  300. /* ***************************************** */
  301. /* Message Target Management API Routines... */
  302. /* ***************************************** */
  303.  
  304.  
  305.  
  306. MessageObject GetMessageTarget (void)
  307. = {0x7023, messageManagerTrap};
  308.  
  309. MessageObject SetMessageTarget (MessageObject)
  310. = {0x7024, messageManagerTrap};
  311.  
  312. void MarkMessageStack (MessageStackMark)
  313. = {0x7025, messageManagerTrap};
  314.  
  315. void UnwindMessageStack (MessageStackMark)
  316. = {0x7026, messageManagerTrap};
  317.  
  318.  
  319.  
  320. /* ******************************* */
  321. /* Message Handler API Routines... */
  322. /* ******************************* */
  323.  
  324.  
  325.  
  326. MessageHandler GetMessageHandler (void)
  327. = {0x7027, messageManagerTrap};
  328.  
  329. long CountMessageHandlerInstances (void)
  330. = {0x7028, messageManagerTrap};
  331.  
  332. void *GetMessageHandlerClassContext (void)
  333. = {0x7029, messageManagerTrap};
  334.  
  335. void *SetMessageHandlerClassContext (void *)
  336. = {0x702A, messageManagerTrap};
  337.  
  338. void *GetMessageHandlerInstanceContext (void)
  339. = {0x702B, messageManagerTrap};
  340.  
  341. void *SetMessageHandlerInstanceContext (void *)
  342. = {0x702C, messageManagerTrap};
  343.  
  344. OSErr NewMessageGlobals (long messageGlobalsSize, MessageGlobalsInitProc)
  345. = {0x702D, messageManagerTrap};
  346.  
  347. void DisposeMessageGlobals (void)
  348. = {0x702E, messageManagerTrap};
  349.  
  350.  
  351. /* **************************************** */
  352. /* Message Sending API Routines...                */
  353. /* **************************************** */
  354.  
  355.  
  356. #ifdef applec
  357.  
  358.     #pragma parameter __D0 SendObjectMessage(__A0, __D1)
  359.     OSErr SendObjectMessage (MessageObject, long messageSelector, ...)
  360.     = {sendObjectMessageSelector, messageManagerTrap};
  361.     
  362.     #pragma parameter __D0 SendObjectMessageTo(__A0, __D1, __D2)
  363.     OSErr SendObjectMessageTo (MessageObject, long messageSelector, MessageHandler, ...)
  364.     = {sendObjectMessageToSelector, messageManagerTrap};
  365.     
  366.     #pragma parameter __D0 StartObjectMessageAt(__A0, __D1, __D2)
  367.     OSErr StartObjectMessageAt (MessageObject, long messageSelector, MessageHandler, ...)
  368.     = {startObjectMessageAtSelector, messageManagerTrap};
  369.     
  370.     #pragma parameter __D0 SendMessage(__D1)
  371.     OSErr SendMessage (long messageSelector, ...)
  372.     = {sendMessageSelector, messageManagerTrap};
  373.     
  374.     #pragma parameter __D0 SendMessageTo(__D1, __D2)
  375.     OSErr SendMessageTo (long messageSelector, MessageHandler, ...)
  376.     = {sendMessageToSelector, messageManagerTrap};
  377.     
  378.     #pragma parameter __D0 StartMessageAt(__D1, __D2)
  379.     OSErr StartMessageAt (long messageSelector, MessageHandler, ...)
  380.     = {startMessageAtSelector, messageManagerTrap};
  381.     
  382.     #pragma parameter __D0 ForwardMessage(__D1)
  383.     OSErr ForwardMessage (long messageSelector, ...)
  384.     = {forwardSelector, messageManagerTrap};
  385.  
  386.     OSErr ForwardThisMessage ()
  387.     = {forwardThisSelector, messageManagerTrap};
  388.     
  389. #else
  390.  
  391.     OSErr SendObjectMessage (MessageObject, long messageSelector, ...)
  392.     = {0x205F, 0x221F, sendObjectMessageSelector, messageManagerTrap, 0x518F};
  393.     
  394.     OSErr SendObjectMessageTo (MessageObject, long messageSelector, MessageHandler, ...)
  395.     = {0x205F, 0x221F, 0x241F, sendObjectMessageToSelector, messageManagerTrap, 0x9EFC, 0x000C};
  396.     
  397.     OSErr StartObjectMessageAt (MessageObject, long messageSelector, MessageHandler, ...)
  398.     = {0x205F, 0x221F, 0x241F, startObjectMessageAtSelector, messageManagerTrap, 0x9EFC, 0x000C};
  399.     
  400.     OSErr SendMessage (long messageSelector, ...)
  401.     = {0x221F, sendMessageSelector, messageManagerTrap, 0x598F};
  402.     
  403.     OSErr SendMessageTo (long messageSelector, MessageHandler, ...)
  404.     = {0x221F, 0x241F, sendMessageToSelector, messageManagerTrap, 0x518F};
  405.     
  406.     OSErr StartMessageAt (long messageSelector, MessageHandler, ...)
  407.     = {0x221F, 0x241F, startMessageAtSelector, messageManagerTrap, 0x518F};
  408.     
  409.     OSErr ForwardMessage (long messageSelector, ...)
  410.     = {0x221F, forwardSelector, messageManagerTrap, 0x598F};
  411.  
  412.     OSErr ForwardThisMessage (...)
  413.     = {forwardThisSelector, messageManagerTrap};
  414.     
  415. #endif applec
  416.  
  417.  
  418.  
  419. #ifdef __cplusplus
  420. }
  421. #endif
  422.  
  423.  
  424. #endif
  425.